/*
 * Copyright 2009-2010 Nanjing RedOrange ltd (http://www.red-orange.cn)
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
package redora.util;

import org.dom4j.DocumentHelper;
import org.dom4j.Element;
import org.jetbrains.annotations.NotNull;
import org.xml.sax.ErrorHandler;
import org.xml.sax.SAXParseException;

import java.util.logging.Logger;

import static java.util.logging.Level.FINE;
import static java.util.logging.Level.INFO;

/**
 * Schema validation error handle.
 *
 * @author Nanjing RedOrange (www.red-orange.cn)
 *
 */
public class DefaultErrorHandler implements ErrorHandler {
    private static final transient Logger l = Logger.getLogger("redora.util.DefaultErrorHandler");

    private final Element errors;

    public DefaultErrorHandler() {
        this.errors = DocumentHelper.createElement("errors");
    }

    /**
     * @return the errors
     */
    @NotNull
    public Element getErrors() {
        return errors;
    }

    /**
     * add exception.
     */
    protected void addException(@NotNull Element element, @NotNull SAXParseException exception) {
        element.addAttribute("column"
                , Integer.toString(exception.getColumnNumber()));
        element.addAttribute("line"
                , Integer.toString(exception.getLineNumber()));

        String publicId = exception.getPublicId();
        if (publicId != null && publicId.length() > 0) {
            element.addAttribute("publicId", publicId);
        }

        String systemId = exception.getSystemId();
        if (systemId != null && systemId.length() > 0) {
            element.addAttribute("systemId", systemId);
        }

        element.addText(exception.getMessage());
   }

    /**
     * (non-Javadoc).
     *
     * @see org.xml.sax.ErrorHandler#error(org.xml.sax.SAXParseException)
     */
    public void error(@NotNull SAXParseException exception) {
        addException(errors.addElement("errors"), exception);
        l.log(INFO, "XML file is invalid: {0}", errors.asXML());
    }

    /**
     * (non-Javadoc).
     *
     * @see org.xml.sax.ErrorHandler#fatalError(org.xml.sax.SAXParseException)
     */
    public void fatalError(@NotNull SAXParseException exception) {
        addException(errors.addElement("fatalError"), exception);
        l.log(INFO, "XML file is invalid: {0}", errors.asXML());
    }

    /**
     * (non-Javadoc).
     *
     * @see org.xml.sax.ErrorHandler#warning(org.xml.sax.SAXParseException)
     */
    public void warning(@NotNull SAXParseException exception) {
        addException(errors.addElement("warning"), exception);
        l.log(FINE, "XML file is invalid: {0}", errors.asXML());
    }
}
